编写视图

    下面是一个返回当前日期和时间作为HTML文档的视图:

    让我们逐行阅读上面的代码:

    • 首先,我们从 django.http模块导入了HttpResponse类,以及Python的datetime库。
    • 接着,我们定义了current_datetime函数。它是一个视图函数。每个视图函数都应接收HttpRequest对象作为第一个参数,一般叫做request。
    • 注意视图函数的名称并不重要;不需要用一个统一的命名方式来命名,以便让Django识别它。我们将其命名为current_datetime,是因为这个名称能够精确地反映出它的功能。
    • 这个视图会返回一个HttpResponse对象,其中包含生成的响应。每个视图函数都要返回HttpResponse对象。(有例外,我们接下来会讲。)

    所以,再重复一遍,这个视图函数返回了一个包含当前日期和时间的HTML页面。你需要创建URLconf来展示在特定的URL这一视图; 详见URL 分发器。

    1. # ...
    2. if foo:
    3. return HttpResponseNotFound('<h1>Page not found</h1>')
    4. else:
    5. return HttpResponse('<h1>Page was found</h1>')

    由于一些状态码不太常用,所以不是每个状态码都有一个特化的子类。然而,如HttpResponse文档中所说的那样,你也可以向HttpResponse的构造器传递HTTP状态码,来创建你想要的任何状态码的返回类。例如:

    1. from django.http import HttpResponse
    2. def my_view(request):
    3. # ...
    4. # Return a "created" (201) response code.

    由于404错误是最常见的HTTP错误,所以处理这一错误的方式非常便利。

    class django.http.Http404

    当你返回一个像HttpResponseNotFound这样的错误时,它会输出这个错误页面的HTML作为结果:

    为了便利起见,也因为你的站点有个一致的404页面是个好主意,Django提供了Http404异常。如果你在视图函数中的任何地方抛出Http404异常,Django都会捕获它,并且带上HTTP404错误码返回你应用的标准错误页面。

    1. from django.http import Http404
    2. from django.shortcuts import render_to_response
    3. from polls.models import Poll
    4. def detail(request, poll_id):
    5. try:
    6. p = Poll.objects.get(pk=poll_id)
    7. except Poll.DoesNotExist:
    8. raise Http404("Poll does not exist")
    9. return render_to_response('polls/detail.html', {'poll': p})

    为了尽可能利用 Http404,你应该创建一个用来在404错误产生时展示的模板。这个模板应该叫做404.html,并且在你的模板树中位于最顶层。

    如果你在抛出Http404异常时提供了一条消息,当DEBUG为True时它会出现在标准404模板的展示中。你可以将这些消息用于调试;但他们通常不适用于404模板本身。

    Django中默认的错误视图对于大多数web应用已经足够了,但是如果你需要任何自定义行为,重写它很容易。只要在你的URLconf中指定下面的处理器(在其他任何地方设置它们不会有效)。

    handler404覆盖了page_not_found()视图:

    1. handler404 = 'mysite.views.my_custom_page_not_found_view'

    handler500覆盖了server_error()视图:

      handler400覆盖了bad_request()视图: